IN THE CLAIMS 



Please amend the claims as follows: 

1 . (previously presented) A query generator for generating a query for obtaining 
selected data from a database, the database having a number of detail tables in which 
data is stored, the query generator comprising a processor which is coupled to the 
database in use, the processor being adapted to: 

a. receive an input indicating the selected data to be obtained to generate a first 

query; 

b. analyze the input and determine whether the input requires a joining of data in a 
plurality of different detail tables, and an aggregation step; and, 

c. if it is determined the input requires a joining of data in a plurality of different 
detail tables, causing the processor to modify the content of the first query indicating the selected 
data to be obtained to generate a second query, the second query being adapted to cause the 
database to: 

i. aggregate the data within each of the plurality of detail tables as required; 

and, 

ii. perform a SQL join operation to join the aggregated data from each of the 
plurality of detail tables, the joined aggregated data representing the selected data. 

2. (previously presented) A query generator according to claim 1, wherein the second 
query causes the database to aggregate the data for each table by causing the database 

to: 

i, select the data within the table for aggregation; and, 

ii. aggregate the data. 

3. (original) A query generator according to claim 2, wherein the data is selected by 
implementing complex folders to generate inline views within the database, the inline 
views being maintained until the aggregation is completed. 
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4. (previously presented) A query generator according to claim 1 , wherein the 
aggregation comprises at least one of: generating an average of the data, generating a sum of the 
data, generating a standard deviation of the data, and generating an evaluation of either a 
maximum or a minimum of the data. 

5. (original) A query generator according to claim 1 , the query generator further 
comprises an input device coupled to the processor to allow a user to generate the input. 

6. (previously presented) A query generator according to claim 5, wherein the input is 
generated by selecting items from a list of possible items, each item representing data 
contained within a respective database table, an action to be performed on data within 

the database, or both data contained within a respective database table and an action to 
be performed on data within the database. 

7. (previously presented) A query generator according to claim 1 , wherein the first 
query and the second query being generated as SQL queries. 

8. (previously presented) A query generator according to claim 1 , wherein the 
aggregation step requires the aggregation of data in different tables. 

9. (previously presented) A database system, the database system comprising: a. a 
database, the database comprising: 

i. a store for storing data, the store having a number of detail tables; and, 

ii. a database processor coupled to the store for obtaining data in 
accordance with a received query; and, 

b. a query generator for generating a structured query for obtaining selected data 
from the database, the query generator comprising a processor adapted to: 

i. receive an input representing a first structured query to be 
generated; 

ii. analyze the input and determine whether the input requires a 
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joining of data in a plurality of different detail tables, and an aggregation step; and, 
iii. if the input requires a joining of data in a plurality of different detail 
tables, causing the processor to modify the content of the first query indicating the 
selected data to be obtained to generate a second structured query, 

wherein the database processor responds to the second structured query 

to: 

(1) aggregate the data within each of the plurality of detail tables 
as required; and, 

(2) perform a SQL join operation to join the aggregated data from each of the 
plurality of detail tables, the joined aggregated data representing the selected data. 

10. (previously presented) A system according to claim 9, wherein the database 
processor and the processor of the query generator are a same processor. 

1 1 . (original) A system according to claim 9, wherein the database processor 
aggregates the data for each table by: 

i. selecting the data within the table for aggregation; and, 

ii. aggregating the data. 

12. (original) A system according to claim 1 1 , wherein the database processor selects the data 
by implementing an inline view to generate complex folders within the database, the complex 
folders being maintained until the aggregation is completed. 

1 3 . (previously presented) A system according to claim 9, wherein the aggregation 
comprises at least one of: generating an average of the data, generating a sum of the data, 
generating a standard deviation of the data, and generating a maximum and a minimum 
evaluation of the data. 

14. (previously presented) A system according to claim 9, the query generator further 
comprising an input device coupled to the processor of the query generator to allow a 
user to generate the input. 



4 



15. (previously presented) A system according to claim 14, wherein the input is 
generated by selecting items from a list of possible items, each item representing data 
contained within a respective database table, an action to be performed on data within the 
database, or both data contained within a respective database table and an action to be 
performed on data within the database. 

1 6. (previously presented) A query generator for generating a query for obtaining selected 
data from a database, the database having a number of detail tables in which data is stored, the 
query generator comprising a processor which is coupled to the database in use, the 
processor being adapted to: 

a. receive an input indicating the selected data to be obtained to generate a first 

query; 

b. analyze the input and determine whether the input requires a joining of data in a 
plurality of different detail tables, and an aggregation step; and, 

c. if it is determined the input requires a joining of data in a plurality of different 
detail tables, causing the processor to modify the content of the first query 

indicating the selected data to be obtained to generate a second query, the second 
query being adapted to cause the database to: 

i. aggregate the data within each of the plurality of detail tables as required; 

and, 

ii. perform a SQL join operation to join the aggregated data from each of the 
plurality of detail tables, the joined aggregated data representing the selected data; 

wherein the data is selected by implementing complex folders to generate inline 
views within the database, the inline views being maintained until the aggregation is 
completed. 
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Please add the following new claims: 

17. (new) A computer program product for generating a query for obtaining selected data 
from a database, the database having a number of detail tables in which data is stored, 
comprising: 

a computer readable medium; 

computer program instructions, recorded on the computer readable medium, executable 
by a processor, for performing the steps of: 

a. receiving an input indicating the selected data to be obtained to generate a first 

query; 

b. analyzing the input and determine whether the input requires a joining of data in a 
plurality of different detail tables, and an aggregation step; and, 

c. if it is determined the input requires a joining of data in a plurality of different 
detail tables, causing the processor to modify the content of the first query indicating the selected 
data to be obtained to generate a second query, the second query being adapted to cause the 
database to: 

i. aggregate the data within each of the plurality of detail tables as required; 

and, 

ii. perform a SQL join operation to join the aggregated data from each of the 
plurality of detail tables, the joined aggregated data representing the selected data. 

1 8. (new) The computer program product of claim 17, wherein the second query causes the 
database to aggregate the data for each table by causing the database to: 

i. select the data within the table for aggregation; and, 

ii. aggregate the data. 

19. (new) The computer program product of claim 1 8, wherein the data is selected by 
implementing complex folders to generate inline views within the database, the inline 
views being maintained until the aggregation is completed. 



6 



20. (new) The computer program product of claim 1 7, wherein the aggregation comprises at 
least one of: generating an average of the data, generating a sum of the data, generating a 
standard deviation of the data, and generating an evaluation of either a maximum or a minimum 
of the data. 
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